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(54) Method and device for channel interleaving and multiplexing 



(57) The invention proposes a method and a device 
for interleaving and multiplexing data conveyed by sev- 
eral transport channels distributed into groups of trans- 
port channels (100). The transport channels (100) of 
one and the same group all have the same quality of 
service. The data of the transport channels of one and 
the same group are processed by one and the same 
processing chain (103A, 103B) specific to the group of 
transport channels. Each processing chain (103A, 
103B) comprises at least one data interleaving step 
(1 54). A multiplexing step (1 52) is provided at the output 
of the processing chains (1 03A, 1 03B). The multiplexing 
step (152) on exit from the processing chains (103A, 
103B) is a multiplexing by shuffling, and all the data in- 
terleaving steps (1 54) are performed within the process- 
ing chains (103A, 103B), before the said multiplexing 
step (152). 
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Description 



EJHIL T P , I ° n fela,eS ,0 a method ,or inter| eaving and multiplexing data conveyed within several 

transport channels d.stnbuted .nto groups of transport channels, the transport channels of one and the same group all 
hav.ng the same quality of service, in which method the data of the transport channels of one and the same group are 
processed us.ng one and the same processing procedure specific to the group of transport channels, each processing 
procedure compr.smg at least one data interleaving step, and in which a multiplexing step is provided at the conclusion 
or the processing procedures. 

[0002] It relates in particular to a channel interleaver and a multiplexer of several transport channels for a system 
m^,f / Curren,| y ""dergoing specification by the 3GPP project (3rd Generation Partnership Project) 
[0003] A channel interleaver is a device placed between the channel coder (respectively decoder) and the transmis- 
sion channel. The object of the channel coder/decoder is to counter the effects of interference. The object of the channel 
interleaver ,s to temporally space apart consecutive symbols on exit from the channel coder (respectively on enlry to 
the decoder). Hence, a flaw impairing several consecutive symbols on the channel, impairs nonexecutive symbols 
on entry to the channel decoder, thus avoiding saturation of the latter. The sought-after effect is referred to as the time 
diversity gain. When this effect is achieved by interleaving, we speak of interleaving gain 

[0004] The 3GPP group is an association whose members originate from several regional standardization bodies 
.nclud.ng .n particular the ETSI (European Telecommunication Standardization Institute) and the ARIB (Association of 
Radio lndustr.es and Businesses). Its object is the standardization of a third-generation telecommunication system for 
mob. es One of the fundamental aspects distinguishing third-generation from second-generation systems is that apart 
from the fact that they will use the radio spectrum more efficiently, they will allow very great flexibility of service Second- 
generation systems offer an optimized radio interface for certain services. For example GSM (Global System for Mo- 
biles) is optimized for the transmission of speech (telephony). Third-generation systems will offer a radio interface 
adapted for All kinds of services and combinations of services. A problem which then arises is that of multiplexing the 
services without impairing the time diversity gain afforded by the channel interleaver 

[0005] One of the issues at stake with third-generation mobile radio systems is that of efficiently multiplexing on the 
rad.o interface, services which do not have the same demands in terms of quality of service. Quality of service is 
defined convent.onally, by at least one criterion comprising in particular a processing delay, a bit error rate and/or an 
error rate in respect of a transport block. 

[0006] The differences in quality of service imply respective transport channels having different tolerances to delays 

?nt ™ ' TH-T in,er,eavin 9 s - as we " *»■ in *e CDMA (Code Division Multiple Access) system envisaged 
in the 3GPP proposal, different rate matching. 

[0007] In the OSI model (Open System Interconnection) from the ISO (International Standardization Organization) 
a telecommunication equipement is modelled by a layered model constituting a stack of protocols where each level is 
a protocol ofler.ng a service to the level above. Level 1 is in particular responsible for implementing channel coding 
and channel .nterleavmg. The service offered by level 1 is referred to as transport channels". A transport channel 
allows the upper level to transmit data with a certain quality of service. The quality of service is in particular characterized 
by the delay and the BER (Bit Error Rate). Since an interleaver brings about a delay which constitutes its time span 
^ ? n8 haVinQ diff6ren1 sensitivi1ies ,0 de'ays may require different interleaves for each transport channel' 
[0008] The known solutions, and in particular those proposed in the 3GPP project, will be described with regard to 
the first few drawings in which: 

Figure 1 is a diagrammatic view illustrating a rectangular interleaver; 

Figure 2 is a diagrammatic view illustrating an incomplete generalized rectangular interleaver 

Figure 3 is a diagrammatic view illustrating the multiplexing of the transport channels on the uplink in the current 

JGPP proposal; 

Figure 4 is a diagrammatic view illustrating the multiplexing of the transport channels on the downlink in the current 
JGPP proposal; 

Figure 5 is a diagrammatic view illustrating multiplexing by concatenation- 

Figure 6 is a diagrammatic view illustrating the destructive effect of multiplexing by concatenation on the interleaving 

[0009] By way of example, a rectangular interleaver is represented in Figure 1 . This rectangular interleaver operates 
as follows: 20 symbols being available for transmission, they are written into a memory space constituting a matrix 
w.th 4 columns and 5 rows. Writing is done row-wise. Thereafter, the symbols are read column-wise and transmitted 
in the order of reading. The number of symbols, 20 in this instance, being interleaved in this way is referred to as the 
depth of the interleaver. The following time diversity is noted: the symbols 0 and 1, respectively denoted by the refer- 
ences 02A and 04A, and which are consecutive before interleaving, are spaced apart after interleaving They are then 
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denoted by the references 02B and 04B. 

[0010] It will be understood that, for the interleaver to operate, it is necessary to wait for 20 symbols to be available, 
hence the delay introduced by the interleaver. 

[0011] As illustrated in Figure 2, it is possible to construct generalized rectangular interleaves, in which it is not 
necessary for the number of columns to be a divisor of the depth. 

[0012] . Represented in Figures 3 and 4 are the block diagrams for interleaving and multiplexing as defined by the 
current proposal by the 3GPP group, although this proposal has not yet been finalized. 

[0013] In these figures, similar blocks bear the same numbers. In both cases the uplink (from the mobile station to 
the network) may be distinguished from the downlink (from the network to the mobile station), and only the transmission 
part is represented. 

[0014] Each transport channel, labelled 100, periodically receives a set of transport blocks from an upper level, 
labelled 1 02. The number of transport blocks 1 00 in this set, as well as their sizes, depend on the nature of the transport 
channel. The minimum period at which the set of transport blocks is supplied corresponds to the time span of the 
interleaving of the transport channel. The transport channels with one and the same quality of service (QoS) are proc- 
essed by one and the same processing chain 103A, 103B. 

[0015] In each of the processing chains 103A, 103B, the transport channels, in particular after channel coding and 
channel interleaving, are multiplexed together by concatenation in step 104. This multiplexing is carried out per mul- 
tiplexing frame. A multiplexing frame is the smallest unit of data for which demultiplexing may be carried out at least 
partially. A multiplexing frame typically corresponds to a radio frame. The radio frames form consecutive time intervals 
synchronized with the network, and numbered by the network. In the proposal by the 3GPP group, a radio frame 
corresponds to a duration of 10 ms. 

[0016] The 3GPP proposal comprises the service-specific coding and interleaving option represented diagrammat- 
ically at 103C. The possibility of such an option is being considered at present since its indispensibility or otherwise 
has not yet been determined. 

[0017] In the general case, a processing chain 103A firstly comprises a step 106 during which a bit word termed the 
FCS (Frame Check Sequence) is attached to each transport block. The bit word FCS is typically calculated by the so- 
called CRC technique (Cyclic Redundancy Check) which consists in considering the bits of the transport block to be 
the coefficients of a polynomial P and in calculating the CRC from the remainder of the polynomial (P+P0) after dividing 
by a so-called generating polynomial G, where P0 is a predefined polynomial for a given degree of P The attaching 
of the bit word FCS is optional, and certain transport channels do not include this step. The exact technique for calcu- 
lating the bit word FCS also depends on the transport channel, and especially on the maximum size of the transport 
blocks. The usefulness of the bit word FCS is to detect whether the transport block received is valid or corrupted. 
[0018] The next step 108 consists in multiplexing together the transport channels (TrCH) of like quality of service 
(QoS). This is because those transport channels which have the same quality of service may use the same channel 
coding. Typically, the multiplexing at 108 is carried out by concatenating the sets of transport blocks with their bit word 
FCS for each transport channel. An example of multiplexing by concatenation is given in Figure 5. 
[0019] The next step, labelled 110, consists in performing the channel coding. 

[0020] On exit from the channel coder 110 there is a set of coded blocks. Typically, in the case of a convolutional 
code, we have either zero or a single coded block of variable length. The length is given by the formula: 

N output = N input / ( Codin 9 rate > + N tait ( len 9 tn of the coded block )- 

with: 

N output = number of bits at output (length of the coded block); 
N input = number of bits at input; 
coding rate = constant ratio; and 

N taii = fixed Quantity of information, independent of N input , serving to empty the channel decoder properly at the 
time the coded block is received. 

[0021] It is onwards of this step 110 that the uplink differs from the downlink, and that the invention differs from the 
current 3GPP proposal, as will be described hereinafter. 

[0022] In each transport channel, whether the uplink (Figure 3) or the downlink (Figure 4), a rate matching step is 
implemented after the channel coding step 110. This step is labelled 112 for the uplink and 114 for the downlink. Rate 
matching is not necessarily performed immediately after channel coding 110. 

[0023] The objective of the rate matching step 112 or 114 is to balance the ratio Eb/I between the transport channels 
with different qualities of service. The ratio Eb/I gives the average energy of a bit with respect to the interference. In a 
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system using multiple access CDMA technology, the greater this ratio the greater is the quality which may be obtained 
It will be understood therefore that transport channels having different qualities of service do not have the same need 
in terms of Eb/I, and that in the absence of rate matching, certain transport channels would have too" good a quality 
of serv«ce relative to their respective needs, fixed as it is by the most demanding channel in terms of quality of service 
Such transport channels would then needlessly cause interference. Rate matching therefore has a role of balancing 
Eb/I. Rate matching is such that X bits at input give Y bits at output, thus multiplying Eb/I by the ratio Y/X hence the 
balancing capability. In what follows, the ratio Y/X is referred to as the rate matching ratio, also known as the rate 
matching ratio. 

[0024] Rate matching is not done in the same way in the uplink and in the downlink. 

[0025] This is because, in the uplink, it has been decided to transmit continuously, since discontinuous transmission 
worsens the peak/average ratio of the radio-frequency power at the output of the mobile station. The closer this ratio 
is to 1 the better. This is because, if this ratio is worsened (that is to say increased), this signifies that the power amplifier 
requires a greater margin (backoff) of linearity with respect to the mean operating point. On account of such a margin 
the power amplifier would be less effective and would therefore consume more for the same average power emitted' 
and this would in particular unacceptably reduce the mobile station's battery-powered endurance. Because it is nec- 
essary to transmit continuously on the uplink, the rate matching ratio Y/X cannot be constant. This is because the sum 
Y 1+ Y 2 +...Y k of the numbers of bits after rate maching must be equal to the total number of bits in the radio frame for 

the data. This number may take only certain predefined values N„ N 2 N p . It is therefore appropriate to solve the 

following system in k unknowns Y, Y k : 



25 



Vie (l,... =X-(Eb i /l)-X i 

Vie {l,..,,k}A.> — ^~ 

' Eb t /I 



ao where X, and Eb/I and P f are characteristic constants of each transport channel, and where it is sought to minimize N- 
from among the p possible values N, , N 2 , .... N p (note: P, is the maximum allowable puncture rate for a coded transport 
channel). r 

[0026] Thus, in the uplink, the rate matching ratios Y/X for each transport channel are not constant from one multi- 
plexmg frame to the next, but are defined to within a multiplicative constant: the pairwise ratios between these ratios 
3s therefore remain constant. 

[0027] In the downlink, the peak/average ratio of the radio-frequency power is in any case very poor since the network 
transmits to several users simultaneously. The signals destined for these users combine constructively or destructively, 
thereby inducing wide variations in radio-frequency power emitted by the network, and hence a poor peak/average 
ratio. It was therefore decided that for the downlink the balancing of Eb/I between the various transport channels would 
be done with a rate matching having a constant rate matching ratio Y/X, and that the multiplexing frames would be 
supplemented with dummy bits, that is to say bits which are not transmitted, that is to say discontinuous transmission 
[0028] Thus, the difference between the uplink and the downlink lies in the fact that in the uplink the rate matching 
112 is dynamic so as to supplement the multiplexing frames, whereas in the downlink the rate matching 114 is static 
45 ^24 mUlt ' pleXlng frames are su PP |em ented through the insertion of dummy bits in the immediately following step 

[0029] The rate matching, whether dynamic or static, is done either by repetition or by bit-puncturing according to 
an algorithm which was proposed to the ETSI by the Siemens company (registered trade mark) in the technical doc- 
ument referenced SMG2/UMTS-L1/Tdoc428/98. This algorithm makes it possible to obtain non-integer puncture/rep- 
etition ratios, and it is given in Table 1 for information 

so 
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Input data: 




Xi 


- number of bits at input. 




- number of bits at output 


Np C = Iy. 


i-xj - number of bits to be repeated or 




to be punctured (if Yi>Xi we 

■ * i 




repeat, otherwise we puncture) 


The puncturing/repetition rule is as follows: 


e = 2*N p / r -Xi -- initial error between the current 




and desired puncture/repetition ratios 


x = 0 


index of the current bit 


while 


x<Xi do 




r if e > 0 then — test whether bit number x 




should be repeated/punctured 




J" puncture or repeat bit number x 


I e = e + (2*N p/r - 2* Xi) — update the 




error 




else 




^ e = e + 2*N p / r — update the 




error 




end_if 




x = x + 1 — next bit 


end do 









Table 1 Repetition or puncturing algorithm 

[0030] The particular feature of this algorithm is that, when it operates in puncture mode, it avoids the puncturing of 
consecutive bits, but on the contrary tends to maximize the spacing between two punctured bits. As far as repetition 
is concerned, the repetition bits follow the bits which they repeat. Under these conditions, it will be understood that it 
is beneficial for the rate matching to be done before interleaving. This is because, in respect of repetition, the fact that 
an interleaving follows the rate matching makes it possible to space the repeated bits apart. In respect of puncturing, 
the fact that an interleaver precedes the rate matching gives rise to the risk that the rate matching might puncture 
consecutive bits on exit from the channel coder. A catastrophic case would be a rectangular interleaver between the 
channel coder and the rate matching, this interleaver having a number of rows equal to the puncture period. In this 
case, all the punctured bits would be consecutive on exit from the channel coder. It is therefore advantageous for the 
rate matching to be done as high up as possible, that is to say as near as possible to the channel coder. 
[0031] Moreover, each processing chain 103A, 103Balso comprises, after the channel coding step 110, a first inter- 
leaver labelled 1 1 6 for the uplink and 1 1 8 for the downlink, followed by a step of segmentation per multiplexing frame, 
labelled 120 for the uplink and 122 for the downlink. The first interleaver 118 is not necessarily located immediately 
after the channel coding 110. 

[0032] For the downlink, it is possible to place the rate matching 114 right at the output of the channel coding 110, 
since the rate matching ratio is constant. Hence, a priori only a single interleaver 118 is needed. However, it will be 
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ISSa^P^h " t 38 ! ° f 3GPP PrOP ° Sa1, 3 S9COnd in,erteav er 126 is necessary after the multiplexing 104 
o° , tl r . ? T fate matchin 9 ra,io mav vaf V with ^ch multiplexing frame, this explaining the need for at 

leas, the f.rs interleaver 116 before the rate matching 112 so as to distribute the bits of the coded block over several 
multip ex.ng frames, and for a second interleave 128 placed after the rate matching 112 so as to space apart the bits 
5 repeated by the rate matching 112. . y 

[0034] - Thus in the block diagrams of Figures 3 and 4 may be seen two interleaves referred to in the block diagrams 
as the first and second interleavers. The first interleaver 116, 118 is an interleave the time span of which is equal to 

mu^fT 9 ! Pa ? corres P° ndin 9 ,rans P° rt cha ""e' This span may be longer than the duration of a 

mult.plex.ng frame and is typically a multiple thereof in a constant ratio. This is why this first interleaver 116 118 is also 
io sometimes referred to as an inter-frame interleaver. 

aTultiple T xhVframe d in ' er ' eaVer 126 ' 128 iS a ' S ° refe " ed to as an in, ra-'^e interleaver since its time span is that of 

Co "f l equent| y' ,he s,e P 01 segmentation per multiplexing frame labelled 120, 122 is situated between the first 
is .I J t a h ! S6COnd 1 28 ' 1 26 in,erleavers < when there ^ a second interleaver). This step consists in segmenting 
he blocks wh.ch are coded and are interleaved by the first interleaver 1 1 6, 1 1 8 into as many segments as is equal to 
the ratio of the t.me span of the first interleaver to the duration of a multiplexing frame. This segmentation is typically 
SSCT T 8 W3y a ' the conca1ena,ion of the segments once again yields the interleaved coded block 
0037] It will be noted that, in the uplink, this segmentation step 120 is necessarily located before the rate matching 

20 1 „ , 18 ^ CaUSe *L e fa,e ma,Chin9 1 1 2 iS d ° ne accordin 9 to a established dynamically multiplexing frame by 
fTamS^'" 9 ' " 15 theref ° re P ° SSible l ° d ° " ° n 3 mit °' d8,a Which may eXtend over several multiplexing 

[0038] In the uplink and the downlink, a step 1 30 of segmentation into physical channels is implemented before each 
second interleaver 126. 128. Likewise, the second interleavers 126. 128 are followed by a step 132 of mapping to 
physical channel for transmission proper. «w»b l " 

25 [0039] In general, it is not desirable to have two interleavers in series. This is because, firstly in the case of a single 
transport channel, there is no need for this since, once the interleaving has been carried out there is no longer any 
time diversity gam to be expected. Thus, rather have a single well optimized interleaver. 

[0040] Moreover, if there are two interleavers in series, it is not possible to define them independently. This is because 
there is a risk that the good time diversity properties acquired by the first interleaver 116 may be destroyed by the 
30 second interleaver 1 28. ' * 

l n °o° c 41 L N ^ W ' ^. ,he ° aSe ° f the 3GPP P r °P° sa '' it wi " be observed that there are two interleavers in series (118 and 
126 in the downl.nk, 116 and 128 in the uplink). Moreover, a second interleaver is placed after the multiplexing 104 of 
the transport channels. The transport channels being independent of each other, it is impossible to determine in advance 
which indices will be those of the bits corresponding to a transport channel on reaching the second interleaver 1 26 
128 and rt is therefore impossible to ascertain how the transport channel will be interleaved. There is therefore a risk 
that the combination of the first 116, 118 and of the second 126, 128 interleavers may have a destructive effect on the 
.me diversity gain, and there is also a risk that this time diversity gain will be further impaired on account of the mul- 
tipiexing 104. 

[0042] Let us thus take the example of two transport channels having very different bit rates, a transport channel A 
and a transport channel B, and let us assume for simplicity that the second interleaver is a rectangular interleaver An 
example .s giver, in Figure 6. The two symbols of B are 4 symbols apart in the multiplexing frame, whereas this frame 
being 24 symbols, they could be 12 symbols apart, i.e. 3 times further apart. 

[0043] Of course, the example of Figure 6 is somewhat exaggerated. In fact, the second interleaver is an MIL inter- 
leaver (Multistage InterLeaver) which is more complex than a simple rectangular interleaver, and the effect shown in 
Figure 6 would not be as great. However, this interleaver is static, it is defined by a table which is fixed once and for 
ail and it cannot therefore be optimal for all cases of multiplexing. 
[0044] Solutions to this problem have already been envisaged. 

[0045] A first state of the art solution consists in providing a first complex interleaver and a second simple interleaver. 
However in the uplmk, the rate matching being placed after the first complex interleaver, for high puncture rates the 
first interleaver and the rate matching cooperate with difficulty. 

\?°^ A "= ordin 9 to a second Prior art solution, the first interleaver is simple and the second interleaver is complex 
t .s then difficult for the second interleaver to have dynamically variable depth, that is to say which varies multiplexing 
frame by mult.plexmg frame, this being made necessary in respect of the grouping together of untransmitted dummy 

[0047] The objective of the invention is to ensure that the time-division multiplexing of the various transport channels 
as well as their rate matching, do not impair the time diversity gain afforded by the channel interleaving without giving 
rise to the accompanying problems of the state of the art solutions. 

[0048] To this end. the subject of the invention is a method characterized in that the said multiplexing step on exiting 
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the said processing procedures is a multiplexing by shuffling, and in that all the said data interleaving steps are imple- 
mented within the said processing procedures. 

[0049] As a variant, the method comprises one or more of the following characteristics: 

each processing procedure implements first and second interleaving steps operating in succession; 
the said second interleaving step comprises a rectangular interleaving step with dynamically variable depth; 
a single rate matching step is provided within each processing procedure between the said first and second inter- 
leaving steps; 

the said first interleaving step comprises an initial step of writing symbols along the rows of a matrix, the number 
of columns of which is equal to the number of multiplexing frames which can be processed during the said step of 
multiplexing by shuffling in the time span necessary for the said first interleaving step, and a subsequent step of 
reading symbols along the columns of the matrix for obtaining blocks of interleaved symbols, and the blocks of 
interleaved symbols obtained following the implementation of the said first interleaving step are segmented so that 
each segment corresponds to a column of the said matrix, the said rate matching step being implemented on each 
of the said segments; 

it comprises a single interleaving step in each processing procedure; 
it comprises, after the said step of multiplexing by shuffling, a step of inserting dummy bits; 
a rate matching step is implemented for each processing procedure, with a static rate matching ratio; 
the said step of multiplexing by shuffling initially comprises a step consisting in associating, with each block to be 
multiplexed, a variable obtained by applying a first evaluation criterion, then, for the construction of the multiplex, 
the following steps, repeated iteratively for all the symbols to be multiplexed: 

a) selecting, as a function of a second evaluation criterion pertaining to the said associated variables, one of 
the blocks to be multiplexed; 

b) extracting from the selected block the next remaining symbol when considering a given order of reading in 
the selected block; 

c) inserting the extracted symbol at the end of the multiplex; and 

d) re-updating the variable associated with the selected block; 

the said step of multiplexing by shuffling is implemented on data blocks the number and size of which vary dynam- 
ically from one multiplexing frame to the next; and 

it is implemented within a radio-communication system implementing CDMA technology. 

[0050] The subject of the invention is moreover a device for interleaving and multiplexing data conveyed within sev- 
35 eral transport channels distributed into groups of transport channels, the transport channels of one and the same group 
all having the same quality of service, comprising: 

a processing chain specific to each group of transport channels, allowing the processing of the data of the transport 
channels of one and the same group, each processing chain comprising at least data interleaving means, and 
40 - multiplexing means provided at the output of the processing chains, 

characterized in that the multiplexing means provided at the output of the processing chains are means of multiplexing 
by shuffling, and in that all the data interleaving means are included within the processing chains. 
[0051] As a variant, the said means of multiplexing by shuffling comprise a hardware accelerator making it possible 
45 to perform a sort of a set of pairs of values comprising, for each of the said pairs, at least: 

an identification value for a class of data blocks having an identical size of data blocks; and 
an error value associated with each class of data blocks, the said error value making it possible to select, iteratively, 
from among the classes of data blocks to be multiplexed, the class of data blocks the symbols of which are to be 
50 appended to the multiplex undergoing formation; 

the said hardware accelerator comprising: 

loading means for the said pairs of values, the said loading means making it possible to load into the input of the 
55 said hardware accelerator at least one new pair of values to be taken into account to form the said set of pairs of 

values to be sorted; 

sorting means for the pairs of values, the said sorting means making it possible to perform at least one so-called 
first-order partial sort assigning the said pairs of values; and 
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- storage means for the said pairs of values, the said storage means making it possible to store, at a given instant 
t, the current state of the said sort of the set of pairs of values, on the basis of a so-called second-order partial sort 
assigning the set of the said pairs of values, in such a way that a single secondorder partial sort is sufficient for 
the said hardware accelerator to deliver at output a pair of values comprising: 
5 - the current minimum error value of the set of error values; and 

the identification value associated with the said minimum error value. 

[0052] Lastly, the subject of the invention is a mobile radio-communication network base station adapted for com- 
municating with mobile stations of the same network, and a mobile radio^communication network mobile station adapted 
io for communicating with base stations of the same network, comprising a device as defined above. 

[0053] The invention will be better understood on reading the description which follows, given merely by way of 
example and with reference to the following drawings in which: 

Figure 7 is a diagrammatic view illustrating the multiplexing of the transport channels according to the invention 
15 for the downlink; 

Figure 8 is a diagrammatic view illustrating the multiplexing of the transport channels for the uplink; 
Figure 9 is a diagrammatic view illustrating the multiplexing by shuffling; 

Figure 10 is a flow chart illustrating the implementation of the method of multiplexing by shuffling used; 
Figure 11 is a diagrammatic view illustrating a memory register; 
?0 Figure 12 is a diagrammatic view illustrating a selection gate; 

Figure 13 is a diagrammatic view illustrating a sorting gate; 

Figure 14 is a diagrammatic view illustrating the hardware accelerator for the "find i such that e = min ie, e. 
eg}" function; 1 1 1> 2 '"" 

Figure 15 is a diagrammatic view illustrating the waveform of the CLOCK, SELECT2 and SELECT1 signals- and 
?5 Figure 1 6 is a diagrammatic view illustrating the format of the content of the registers. 

[0054] In the state of the art, the second interleaver 1 26, 1 28 of the 3GPP proposal owes its position to the fact that 
it counteracts the interleaving gain destruction effect of the multiplexing by concatenation 104 of the 3GPP proposal 
[0055] According to the invention, and as represented in Figures 7 and 8, the multiplexing 104 by concatenation is 
'0 replaced by a multiplexing 152 by shuffling. 

[0056] The introduction of a multiplexing 1 52 by shuffling makes it possible to eliminate the second interleaver from 
the downlink and to retain only the first interleaver labelled 154 in Figure 7. In the uplink, the second interleaver 128 
located after the multiplexing step 1 04 is eliminated. Only the first interleaver labelled 1 56 in Figure 8 remains to which 
however has been added a second interleaver 1 58. However, this second interleaver 1 58 is provided in each processing 
chain 103A, 103B upstream of the multiplexing step 152. In the uplink, the interaction between the first 156 and the 
second interleaver 1 58 can be dealt with as follows. 

[0057] The first interleaver 156 is a rectangular interleaver having as many columns as is equal to the ratio of the 
interleaving time span for the corresponding transport channel(s) to the duration of the multiplexing frame 
[0058] For example, if the interleaving time span for the transport channel is equal to 40 ms, and the multiplexing 
frame corresponds to a radio frame, i.e. 10 ms, the first interleaver 156 is a rectangular interleaver with 4 columns 
The segmentation per multiplexing frame 120 is done according to the columns of the first interleaver 156 that is to 
say the segment corresponding to the i* multiplexing frame in the period over which the transport channel is interleaved 
corresponds to the i th column of the first interleaver 156. 

[0059] The first interleaver 156 and the associated segmentation per multiplexing frame 120 may advantageously 
be replaced by an FS-MIL inter-frame interleaver (Fixed block-Shape Multi-Stage InterLeaver). The method which has 
already been described is a particular case of the FS-MIL interleaver. The FS-MIL interleaver has been defined by the 
3GPP within the current specification referenced St. 12 version 1.1 .0. 
[0060] Table 2 below describes the algorithm for the FS-MIL interleaver. 
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5 


input data: 








N: 


integer size of the block to be 


interleaved and to 






be segmented 








X: 


symbol array [ 0 N-l ] - block 


of symbols to be 






interleaved and to be segmented 






10 


m : 


integer sequence number of the 


segment at output. 






me (0, 1, ... , F-l} 








a: 


permutation of { 0 , 1 , . . . , F-l } 










permutation of 


the columns 


IS 


Y: 


symbol array [ 0 .. L-l ] - segment/ at output 


we have 






L = 


" N - a(m)~ 










F 




20 


The algorithm is as follows: 








y 


= o(m) — positions of the 


symbols to be 






interleaved 






x : 


= 0 position in the 


interleaved 


25 




segment at 


output 






while y<N do 










Y[x] = X[y] interleave a 


symbol 




30 




x = x + 1 next interleaved symbol 




y: = y + F symbol to be interleaved 




end do 







Ji> Table 2 FS-MIL interleaver followed by segmentation per 

multiplexing frame 

[0061] The interleaver also comprises a matrix having a number of columns which is equal to the number F of mul- 
40 tiplexing frames in the time span of an interleaving period for the transport channei(s). The symbols to be interleaved 
are written into the matrix row-wise. Then the columns are permuted according to a permutation a of {0, 1, F-1}. 
After permutation, the column in position i is in the position a _1 (i). The columns after permutation are therefore the 
original columns a(0), a(1), .... a(F-1). 

[0062] Thus, the order of the symbols in the segments produced is the same as in the input block, thereby making 
45 it possible to prevent the puncturing done by the rate matching from interacting unfavourably with the interleaving. In 
the FS-MIL interleaver described in the current specification S1.12, a is given for the possible values of F in the 3GPP 
system in the table below: 



F 


(o(0), o(1),...,a(F-1)) 


1 


(0) 


2 


(0,1) 


4 


(0,2,1,3) 


8 


(0,4,2,6,1,5,3,7) 



The second interleaver 1 58 is a rectangular interleaver with dynamically variable depth equal to the integer part of the 
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square root of the size of the block to be interleaved. An algorithm for carrying out this interleaving is given in Table 3. 



10 



15 



20 



25 



30 



35 



X 
Y 



Input data: : 

N: size of the block to be interleaved 

symbol array [0 N-l] — block in to be interleaved 
symbol array [0 N-l] — block out interleaved by the 

algorithm 
The algorithm is as follows: 

y = 0 — position of the symbol to be interleaved 

— position of the interleaved symbol 

— number of columns, |_J notation for the 
integer part 

— size of the largest complete block < N 



x = 0 

K = LVnJ 

N s = Ln/kJ*K 



while x< N do 

Y[x] = X[y] 
x = x + 1 
if y <N-K then 




else 



y = y + K 



— interleaving of a symbol 

— next symbol to be interleaved 

test whether the position 
should be aliased 

— no aliasing 



aliasing 
if y > Ns then 

y = y - (Ns-1) 



else 



y = y - (Ns-K-1) 



end if 



aliasing in 
incomplete 
part 

aliasing in 
complete part 



end if 



end do 



40 



Table 3 Variable-depth 
inter leaver 



generalized rectangular 



[0063] An alternative algorithm is given in Table 4. 
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Input data: 

N: size of the block to be interleaved 
X: symbol array [ 0 N-l ] — block in to be interleaved 
Y: symbol array [0 .. N-l] — block out interleaved by the 

algorithm 

The algorithm is as follows: 

y = 0 position of the symbol to be interleaved 

x - 0 — position of the interleaved symbol 

K = LVnJ — number of columns, L.J notation for the 

integer part 
L = Ln/kJ — number of complete lines 

N s = L*K — size of the largest complete block < N 



while x< N do 

Y[y] = X[x] 
x = x + 1 



< 



interleaving of a symbol 
next symbol to be interleaved 



if y > (L+1) # (N-Ns) then 



if y > N-L then 



test whether in the 
same column, row L+l 
is in its complete 
part 

test whether aliasing 
in incomplete part 



y = y - (N-L-l ) — aliasing 



else 



y « y + L 



— no aliasing 



end if 



else 



y £ N-L-l then 



-S y = y - (N-L-2) 

else 

y = y + L + 1 
end_if 
end if 



test whether aliasing 
in complete part 

aliasing 



— no aliasing 



end do 



Table 4 Variable-depth generalized rectangular 
interleaver 



[0064] These algorithms are simple enough for the interleaving positions to be calculated on the fly, that is to say 
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symbol by symbol. Hence, they require no tabulation, that is to say for example a correspondence table such that the 
™«? m ? nt ,S ,he POSi,i ° n a ' ,er ,he interlea ™9 of a symbol in nth position before interleaving 
5?2 ., f US "? te th3t !" 0386 Wh6re ,he inter,eavin 9 time span for the transport channel is equal to the duration 
as Z "le oZlT™' in,er ' eaVer 156 thS Se 9 mentation 120 would ^e.no effect, and could S 

Thecomb | na,ion °' ,he first interleaver 156 and of the segmentation 120 is such that the bits in each segment 
are n the same order .n the segment as in the block before interleaving. Under such conditions, it will be understood 

LT^TT f T 1 56 ^ °' SeC ° nd in,er ' eaVer 1 58 Can have "° dest ™«- «"-t on the interSnl 
ga n. Moreover, when the rate matching is done by puncturing, as the rate matching algorithm at 112 (Table 1 ) does 

^, n U ;, C h e . C ° n r U,iVe bi,S> 35 the firSt in,er,eaver 156 " reserves the ^^ted to a egm?nt, it flws 
™ f ° 6S ,he fate matChin9 pUnC,ure consecut^e bits on exit from the channel coder 110 

n^L/^ a \T e I'! S{ inte : leaver 156 P resefves th * °^er locally to a segment, the rate matching algorithm 
proceeds by taking the bits ,n order and by repeating/puncturing according to this order. It is then possible to achieve 

on the a 6 ! w^Ta f e ^"f^ ™ ^ ^ ' 58 by 031011,3,1,19 PO-Z 

wri ,« ni <Z^l? r V °' P unctun "9/™peating. This allows the maximum possible limitation on reads and 
writes of symbols in random access memory, this being an appreciable saving of time 

SromThrJir'^'rK 6 " sh ? mn ? at 152 is done according to an a,9 ° rithm 9iven m ™° 5 **** « s i nsP i- 

ration from the rate matching algorithm given in Table 1 . H 



Input data: 

Xt : symbol array [0 ] 



— i st 



block to be multiplexed 

— w m 

X, : symbol array [0 .. Ni -1 ] - i"> block to be multiplexed 

• • • 

X p : symbol array [0 . . N p -1 ] 
Y : symbol array [0 . .N-l ] 



_th 



P block to be multiplexed 
multiplex N = N!+n 2 +...+n p 



The algorithm is as follows: 
for i = 1 to p do 

ei = N-N t — initialize error for all the blocks to be 

multiplexed 
for i = 1 to p do 

Xi = 0 — initialize position in all the blocks to 

be multiplexed 

while x <Ydo initiali2e P°«tion in the multiplex 

" Find j such that e, = min { ei , e 2/ . . . , e p } 
Ytx] = Xjfxj] — multiplex 
x = x + 1 

Xj = Xj + 1 

If Xj = Nj then 



Else 



— block j 
selected 



will no longer be 



end do 



End if 



ej = e 3 + 2 • (N-Nj ) 



Table 5 Multiplexing by shuffling 

[0069] In this algorithm, an error, given by the formula between the ratios x/x and N/N is calculated The block 
which ,s selected for the multiplexing is the one for which tfiS error is smallest, sincere aim /s to minimize the mTxirn'm 
error during the execution of the algorithm. For the algorithm to be fully defined, it is necessary that the operation "find 
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j such that ej = min {e 1( e 2 , .... e p } B be defined when the minimum is attained at several points. For example, we can 
define j by the algorithm of Table 6. 



j: = 1; 
i : ~ 2; 
while i<p do 

If e x < ej then j: = i; 

end_do 

Table 6 

75 

[0070] Stated otherwise, a lexicographic order relation over the set of pairs (e y \) is considered. This relation is such 
that if ej<e| then (ej,i)<(ej,j), and if 6j = ej then if moreover i<j we have (ej,i)<(ej,j). Thus, if the values of the errors ej 
and 6j are different, then the order of the value pairs (e it i) and (e^.j) is the same as that of the errors ej and e^. Otherwise 
the order of the pairs (ej, i) and (e y \) is the same as that of the identification values i and j of the blocks to be multiplexed. 
20 The identification value j determined by the operation "find j such that ej = min{ej,...., e p } u is in fact that for which the 
pair of values (e- v \) is the minimum for the lexicographic order of the set of value pairs {(e-,,1 ),..., (e pi ...,p)}. This operation 
would then be better defined as "find j such that (e^j) = min {(e-,,1) (e p ,p)} B . 

[0071] The multiplexing by shuffling algorithm implemented in the method according to the invention is illustrated in 
Figure 10. 

25 [0072] Thus, initially, in step 500, a variable ej is associated with each block to be multiplexed. This variable ej is 
calculated by applying a first evaluation criterion which, here, gives, for the block having the identification value j, the 
value of the initial error ej = N - Nj where N is the total length of the multiplex to be obtained and Nj is the number of 
symbols of block j to be multiplexed. In step 502, one of the blocks to be multiplexed is selected by applying a second 
evaluation criterion pertaining to the associated variables e^ defined on the basis of the first criterion. In the example 

30 considered, the second criterion leads to the selecting, from among all the blocks, of that one the error ej of which is 
smallest. 

[0073] In the block thus selected, the next remaining symbol, considered in the direction defined for the extraction 
of the symbols, is extracted in step 504. This extracted symbol is then inserted at the end of the multiplex undergoing 
definition in step 506. 

35 [0074] With a view to supplementing the multiplex, with another symbol extracted from a block wh ich is not yet empty, 
the variable associated with the block from which the last symbol has just been extracted is re-updated in step 508. 
[0075] Steps 502 to 508 are repeated so long as the blocks to be multiplexed are not ail empty. This repetition is 
managed in particular by a test performed in step 510. 

[0076] The algorithm defining the multiplexing by shuffling can operate on a variable number of blocks of variable 
40 size. Also, when the transport channels have variable bit rates, the multiplexer carries out dynamic multiplexing, varying 
multiplexing frame by multiplexing frame. 

[0077] By virtue of the multiplexing by shuffling 152, only a single interleaver 154 is needed in the downlink, this 
interleaver can for example be a rectangular interleaver such as the one given in Table 1 . This interleaver 1 58 has the 
advantage of having variable depth, and of being able to calculate on the fly, that is to say symbol by symbol. 

45 [0078] In a word, the invention, by using a single interleaving method and being able to calculate on the fly the 
interleaving positions of the interleaved symbols for any depth whatsoever, fits from the outset with the logic of up- 
gradeability and flexibility. Any interleaver having the same characteristics of variable depth and on-the-fly calculation 
capability could be used in the invention instead of the rectangular interleaver defined in the algorithm of Table 3. 
[0079] Finally, in the downlink, an insertion of dummy bits 160 is carried out in last place in the invention, between 

so the segmenting of the physical channels 1 30 and the mapping to physical channel 1 32. On the other hand, it is recalled 
that, in the 3GPP proposal, the insertion of dummy bits is carried out before the second interleaver 126. Insertion in 
last place makes it possible more easily to control the time position of the discontinuous-transmission dummy bits. In 
particular, it is thus simpler to group them together temporally, so as to have a discontinuous transmission period of 
significant duration. Keeping the discontinuous-transmission dummy bits makes it possible to arrange for periods during 

55 which the mobile station can make measurements on other carrier frequencies, with a view to a possible handover 
[0080] In the algorithm defining the multiplexing by shuffling given in Table 5, the limiting step is that of the operation 
"find j such that ^ = min {e 1l e 2 ,...,ep} u which is defined in Table 6. 

[0081] The SIEMENS (registered trade mark) algorithm of Table 1 is a particular case of the multiplexing by shuffling 
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a gorrthm. Thus, .n the case of the multiplexing of two blocks onfy, it is possible to rewrite the algorithm whilst havinq 

XL 9 h "k , = "J" 62 " iS ,h6n SUffiCient ,0 ,est the si 9 n of e so as to asc ^ain from which of the Two 2 
X£« 3 Symb °'' ,h ' S b6ing Simpler than searc hing for the minimum of a, and e, P 

hfshufflSr^i °' !' 90rithm j S also P° ssib,e of having a criterion c, per block i at the input of 

tooetSe hf SS? TJ ^ VS ! 3 Cri,eri ° n Pef P ° S - ib ' e SiZS Ni ° f thiS bloCk 11 is ,h ° refore sutficient to 9~«P 
SET Th ^ T' 38 IOn9 38 ,hefe are any ' SO as to reduce the complexity of the algorithm. 

wrmen as in'ab.i" ' ' ^ * ^ Pi blOCkS X *- of size N i" th - e " the a '9orithm can be 
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Input data for the algorithm: 

X lfl : symbol array [ 0 Nx-1 ] 



Xx, p i: symbol array [ 0 Ni~l ] 
X 2 ,i: symbol array [ 0 .. Ni-1 ] 



1 



St 



block 



to 



be 



multiplexed 



to 



pr" block 
multiplexed 
(P!+l)th block to 
multiplexed 



be 
be 



Xp,p : symbol array [ 0 N p -1 ] 



block to be 
multiplexed 



Y: symbol array [0..N-1] — multiplex N 

Pi*N 1 +p2.N 2 +...+Pp-Np 

The algorithm is as follows: 
for i = 1 to p do 

ei = N-Ni — initialize the error criterion 

all the block sizes 



for 



for i « 1 to p do 

x = 0 initialize the position in the multiplex 

while x < N do 

f find j such that e^ - min {ei, e 2 /.-./ e p } see Table 5 
for i : = 1 to Pj do 

Y[x] : = Xj (i [Xj] — multiplex 

i — X: = x + 1 
enL-do 
x^: = Xj + 1 
if Xj = Nj than 

e 3 : = +oo — the blocks of size Nj will never 

again be selected 

Else 

e-j = ej + 2 ■ (N-Nj ) 
\^ end^if 
end do 



< 



Table 7 Multiplexing by shuffling 

[0084] As an alternative to the software described for performing the operation "find j such that = min {e-,, e 2 , .. 
ep}" of Table 6, it is possible to implement a hardware accelerator 1 1 30. Such a hardware accelerator 1 1 30 is described 
below in conjunction with Figure 14. 

[0085] The hardware accelerator 1 1 30 comprises the following means: 

• Storage means 1160 comprising memory latch registers 1000. A memory register 1000 is represented in Figure 
11 . Such a register 1000 comprises four input ports RESET, ENABLE, CLOCK and D, and an output port Q. The 
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D and Q ports are L-bit data ports, whereas the RESET, ENABLE and CLOCK ports are 1-bit control ports The 
Q port reflects the current value of the internal state of the register 1000. The D port serves to present a new value 
for this internal state. The new value is taken into account upon a rising edge of the clock arriving on the CLOCK 
port when the ENABLE port is active. Thus, the current value of the register 1000 can flip upon a rising edge of 
the clock. Conversely, while the ENABLE port is in the inactive state, the current value of the internal state of the 
register 1 000 is preserved upon the rising edges of the clock. Finally, the RESET port, when it passes at any instant 
to the active state, forces the internal state of the register 1000 to be initialized completely to zero Each of the 
registers referenced 1001 to 1008 in Figure 14 is identical to the register referenced 1000 in Figure 11 
• Sorting means 1140 comprising elementary sorting gates 1120 and selection gates 1110. The sorting means 1140 
are fed by the outputs of the registers 1001 to 1008, through a port DATAJN which makes it possible to take into 
account the values of a new triplet ej , j-i}, and of input signals labelled SELECT 1 and SELECT 2 The input 
signal SELECT2 is used to define two modes of a so-called first-order partial sort described later The input signal 
SELECT1 makes it possible when it is equal to 0, as explained later, to load input values presented on the DATA IN 
port. 

The sorting means 1140 make it possible to perform a first^rder partial sort, at the conclusion of which the content of 
the registers 1 001 to 1 008 is not necessarily completely sorted. The result of this firstorder partial sort is then fed back 
into the registers 1001 to 1008. Stated otherwise, each output of the selection gates 1110 is linked to the D input of 
one of the corresponding registers 1001 to 1008 (link labelled from 1 to 8 in a circle in Figure 14) The firstorder partial 
sort .s performed exclusively, according to one of the following two modes, referred to as the first and second modes 
respectively: 

- During the first mode, the input signal SELECT2 is equal to 1 , the contents of the register pairs referenced 1 001 
1002; 1003, 1004; 1005, 1006 and 1007, 1008 are sorted elementarily in ascending order: tor example on con- 
cluding the elementary sorting of the content of the register pair referenced 1001 , 1002, the smaller value is in the 
register referenced 1001 , and the larger value in the register referenced 1 002 

- During the second mode, the input signal SELECT2 is equal to 0, the contents of the register pairs referenced 
1002, 1003; 1004, 1005 and 1006, 1007 are sorted elementarily in the same order, namely ascending order. 

We consider for example the case where the value of the input signal SELECT2 changes with each clock tick 
A second-order partial sort implementing not only the sorting means 1 1 40, but also the storage means 1 000, comprises 
the success.on of a first-order partial sort in the first mode and a first-order partial sort in the second mode Thus each 
register pa.r assigned by the first-order partial sort in the second mode overlaps two register pairs assigned by the 
firsl-order partial sort in the first mode. It will therefore be understood that the second-order partial sort (by alternating 
the two modes of the first-order partial sort) is not restricted to the content of the register pairs taken separately but 
pertains to the entire contents of the registers. 

In this way, by implementing the second-order partial sort in a sufficient manner, that is to say as often as the number 
of registers divided by two, the entire contents of the registers is sorted 

Moreover, when the value of the input signal SELECT1 is equal to 1, the value of the output from the first register 
referenced 1001 is selected as output from the loading means 1150, and hence as input for the sorting means 1140 
Such a selection makes it possible to take into account, during a first clock tick, a new value presented on the DATAJN 
port, substring this for the last value contained in the first register 1 001 , namely the minimum value of the contents 
of the registers 1001 to 1008. 

• Selection gates 1110. A selection gate 1110 is represented in Figure 12. Such a gate 1110 comprises three input 
ports C, DO, D1, and an output port 0. The ports DO, D1 and O are L-bit data ports, whilst the port C is a 1-bit 
control port. The port O takes the value of the port DO when the control port C is at zero, otherwise C is at 1 and 
O takes the value of the port D1 . ' ' 

• Sorting gates 1120. A sorting gate 1120 is represented in Figure 13. Such a gate 1120 comprises two input ports 
DO and D1 , and two output ports O0 and 01 . These four ports are L-bit data ports. The ports O0 and 01 respectively 
take the values of the ports DO and D1 when DO is smaller than, or equal to, D1 according to a given order relation 
Otherwise, the ports O0 and 01 respectively take the values of D1 and DO. Thus, the two values presented as 
input to the ports DO, D1 are sorted at the output of the ports O0 and 01 

• Loading means 1150 comprising a selection gate. The loading means 1150 feed the sorting means 1140 The 
loading means 1150 make it possible, conditioned by the value of the input signal S ELECT 1 , to output either the 
value of the port DATAJN (when the input signal SELECT1 is at 0), or the value of the content of the first register 
1001 (when the input signal SELECT 1 is equal to 1). 
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[0086] The hardware accelerator 1 1 30 of the invention, represented in Figure 1 4, is capable of performing the function 
"find j such that ej = min {e 1( e 2 ..., e p }" for a number p equal to at most 8 (this number being taken by way of example). 
In the figure, transfers are represented by pairs of circles bearing a number. Thus the two circles bearing the number 
1 are in electrical contact. 

5 [0087] The hardware accelerator 1130 will be better understood on considering Figure 15. Via means which are not 
represented in Figure 14, the signal SELECT2 is made to take the values 0 and 1 alternately at the sampling instants 
given by the rising edges of the clock signal. Noting that the inputs DO and D1 are in reverse order from one selection 
gate 1110 to the next, it will be understood that when the signal SELECT2 is equal to 1 then only the sort performed 
by the sorting gates 1120A at odd positions (1 st , 3 rd , etc. . .) is taken into account so as to update the value of the latch 

w registers 1 000. When the signal SELECT2 is equal to 0, the reverse holds, thus the sort performed by the sorting gates 
1 120B at even positions (2 nd , 4 th , etc. ...) is taken into account. 

[0088] With such a layout, it will be understood that if moreover the signal SELECT1 is equal to 1, the signals 
ENABLE 1 and ENABLE2 are equal to 1, and the signal RESET is equal to zero, while the contents of the registers 
end up being sorted in such a way that the values increase from left to right in Figure 14. 
rs [0089] The format of the content of a register 1000 is represented in Figure 16. It comprises: 

an indicator of the value of j of the bits 0 to 2 (2 3 = 8 is the value for p in our example); 

an indicator of the vatue of ej of the bits 3 to L-2. This indicator is relevant when e } * +«>, arbitrary otherwise; and 
a bit I at 1 when ej * +<*>, and at zero otherwise. 

20 

[0090] Thus, the format of the content of the registers 1001 to 1008 makes it possible essentially to distinguish 
between two items of information: 

an indicator j identifying the block to be selected; and 
25 - an error value (lj, ej) allowing selection. 

[0091] This error value can have an infinite value (lj = 1) so that block j is no longer selected when all its symbols 
have been appended to the multiplex under formation, or finite (lj = 0) when there are still symbols in block j which are 
not yet in the multiplex under formation. 
30 [0092] In the embodiment described here, a specific bit (lj, bit L-1) serves to mark the infinite value. Thus, in Tables 
5 and 7, the operation n ej: = +<~ a amounts to setting this specific bit to 1 , whilst during the operations "ej: = N-Nj" and 
"ej: = ej+2.(N-Nj) n this specific bit is set to zero, and the value is loaded into bits 3 to L-2. 

[0093] In another embodiment, there is no specific bit lj to mark the infinite value, and the finite or infinite value of ej 
is stored in bits 3 to L-1 . On the other hand, there is a certain threshold labelled max, such that ej is regarded as finite 
35 when ej<max, and as infinite for any value such that ej>max. To this end, the number of bits L-3 over which ej finite or 
infinite is preserved is sufficient to keep the value max+1 . Moreover, the threshold max is such that it is never exceeded 
when ej is updated by the operations "ej:=N-Nj" and "ej: = ej+2.(N-Nj) n of Tables 5 and 7, and the operation "ej: = +~ H 
amounts to storing a larger value than max, for example max+1 or else (2 L " 3 -1 ). 

[0094] Thus the canonical order over the natural integers, applied to the contents of the registers 1000, is sufficient 
40 to perform the desired sort so as to obtain the function "find j such that e x = min {e 1( e 2) ... ,e p }°. 
[0095] The hardware accelerator 1130 operates as follows: 

[0096] Firstly, all the registers 1000 are reset to zero with the aid of the RESET port. During normal functioning, the 
RESET input remains at zero, that is to say in an inactive state. 

[0097] When the signal SELECT1 is at 1 , the sort is performed on the existing values of the (lj.ejJ-1 ), otherwise, the 
45 signal SELECT 1 can be set to zero when the signal SELECT2 itself also takes the value zero, this making it possible 
to change the value in the first register by presenting a new value on the DATAJN port; Thus all the registers may be 
initialized by loading the values {0,N-Ni,i-1} for i=1 to p into the first register at most every second clock pulse (or tick). 
As the initial values are necessarily non-zero since, for any i, we have N-Nj*0, then as long as all the registers 1001 
to 1008 have not been loaded, after two clock ticks, one of the zero values given initially to the "reset" will be dropped 
50 back down into the first register and may be overwritten by the next value of {0,N-Nj, i-1 }. 

[0098] When the p values have been loaded in this way, it is sufficient to read, on the DATA_OUT port, the value of 
j in the three least significant bits. This value is the one which satisfies ej = min {e v ..,e 8 }. After having incremented the 
vatue ej by 2(N-Nj), or having set it to +«>, the new value of the triplet {Ij.ej.j-I} can be reloaded into the first register, 
by presenting this value on the DATAJN port, by setting the signal SELECT1 to zero when the signal SELECT2 also 
55 goes to zero. After two clock ticks afterwards, the new value of j given by the function "find j such that ej = min {e-,, 
e 2 ,... e p }" can be read on the DATA_OUT port. 

[0099] It is important to note that the only constraint to be observed, to obtain optimal functioning of the hardware 
accelerator described, ties in the fact that between two zeroings of the input signal SELECT 1 , the input signal SELECT2 
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must have changed value at least twice. 

[0100] Thus, assuming that the input signal SELECT2 changes value with each clock tick and that the registers 1 001 
to 1008 have already been loaded, then after having presented a new triplet {l jt e^ j} on the DATAJN port by setting 
the input signal SELECT1 to zero, two clock ticks are sufficient in order for the value of the minimum error e to be 

5 dropped back down, within the first register 1 001 , together with the associated values of j and I-. Thus, by presupposing 
in this example that the input signal SELECT1 takes the value 0 only on the same clock ticks for which the input signal 
SELECT2 is equal to zero, it is guaranteed that between two zeroings of the input signal SELECT1, the input signal 
SELECT2 has twice changed value. Thus, after having presented a new e^ j} by setting the input signal SELECT1 
to zero, a second-order partial sort starting at the same moment is sufficient to obtain the minimum triplet {I- e j} on 

'0 the DATAJDUT port. v v 

[0101] In another embodiment, the same result could be obtained by presupposing that the input signal SELECT1 
has the value 0 only on the clock ticks for which SELECT2 is equal to 1. In this case, the secondorder partial sort 
would be defined by firstly doing a first-order partial sort in the second mode, and thereafter a first-order partial sort in 
the first mode. 

[0102] A crucial point in the performance of this device is that there is no need for the values of all the registers to 
be completely sorted. It is sufficient to be certain that the content of the first register is the minimum of all of them. 
Thus, the sort may be carried out in parallel with the multiplexing. This is because there is no need to wait for the new 
value of the triplet {lj.e^j-1) after incrementation by 2(N-Nj), or setting to +<~, to be propagated to what would be the 
definitive position if we had waited for the sort to be carried out completely. Two clock ticks are sufficient for the incre- 
mented value to be propagated far enough for the value in the first register to be the minimum. 
[0103] Thus, if the algorithm were performed at the fastest possible speed with the hardware accelerator 11 30 de- 
scribed, the signals SELECT1 and SELECT2 would still have the same value, the value of j such that e j= min {e,, .... 
e p } would be read on the DATA_OUT port when the signal SELECT1 is equal to 1 , and the incremented value of the 
triplet {*j»€tj.i-1 } read would be written when the signal SELECT1 had gone to 0. Moreover, a cue which makes it possible 
to demultiplex and decode a multiplexing frame so as to obtain the transport channels is referred to as a combination 
of transport formats. This cue can be transmitted explicitly multiplexing frame by multiplexing frame. This is referred 
to as explicit bit rate detection. 

[0104] Another so-called implicit method consists in not forwarding this cue. The receiver of the multiplexing frame 
must then try all the possible transport format combinations until the test of the CRC word attached to the transport 
30 block is positive for at least a certain number of transport blocks. 

[0105] Given that the transport channels do not all have the same transmission interval, the CRC words of the trans- 
port blocks of a transport channel having a transmission interval equal to several multiplexing frames can only be tested 
after these multiplexing frames have been completely received. 

[0106] Now, the multiplexing is done multiplexing frame by multiplexing frame according to the combination of trans- 
35 port formats. 

[0107] It is therefore simpler when this multiplexing does not depend on the combination of transport formats. This 
can be achieved by inserting discontinuous transmission dummy bits before the multiplexer 152 of transport channels 
with different qualities of service (QoS) so that the multiplexed blocks have a constant size. 

[0108] Thus, it is possible, through minor modifications to the method, to use the same coding, interleaving and 
multiplexing means in the network when the method implemented is implicit bit rate detection or explicit bit rate detec- 
tion. 



40 



Claims 

1. Method for interleaving and multiplexing data conveyed within several transport channels (100) distributed into 
groups of transport channels, the transport channels of one and the same group all having the same quality of 
service, in which method the data of the transport channels of one and the same group are processed using one 
and the same processing procedure (103A, 103B) specific to the group of transport channels, each processing 
procedure ( 1 03A, 1 03B) comprising at least one data interleaving step (1 54; 1 56, 1 58), and in which a multiplexing 
step (152) is provided at the conclusion of the processing procedures (103A, 103B), characterized in that the said 
multiplexing step (152) on exiting the said processing procedures (103A, 103B) is a multiplexing by shuffling, and 
in that all the said data interleaving steps (154; 156, 158) are implemented within the said processing procedures 
(103 A, 103B). 

2. Method according to Claim 1 for transmission along an uplink from a mobile station to a fixed network, characterized 
in that each processing procedure (103A, 103B) implements first and second interleaving steps (156, 158) oper- . 
ating in succession. 
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Method according to Claim 2, characterized in that the said second interleaving step (1 58) comprises a rectangular 
interleaving step with dynamically variable depth. 

Method according to Claim 2 or 3, for transmission along an uplink from a mobile station to a fixed network, char- 
acterized in that a single rate matching step (112) is provided within each processing procedure (103A, 103B) 
between the said first and second interleaving steps (156, 158). 

Method according to Claim 4, characterized in that the said first interleaving step (156) comprises an initial step 
of writing symbols along the rows of a matrix, the number of columns of which is equal to the number of multiplexing 
frames which can be processed during the said step of multiplexing by shuffling (152) in the time span necessary 
for the said first interleaving step (156), and a subsequent step of reading symbols along the columns of the matrix 
for obtaining blocks of interleaved symbols, and in that the blocks of interleaved symbols obtained following the 
implementation of the said first interleaving step (156) are segmented so that each segment corresponds to a 
column of the said matrix, the said rate matching step (112) being implemented on each of the said segments. 

Method according to Claim 1 , for transmission along a downlink from a fixed network to a mobile station, charac- 
terized in that it comprises a single interleaving step (154) in each processing procedure (103A, 103B). 

Method according to Claim 1 or Claim 6, for transmission along a down link from a fixed network to a mobile station, 
characterized in that it comprises, after the said step of multiplexing by shuffling (152), a step of inserting dummy 
bits (160). 

Method according to any of Claims 1 , 6 or 7, for transmission along a downlink from a fixed network to a mobile 
station, characterized in that a rate matching step (114) is implemented for each processing procedure (103A, 
103B), with a static rate matching ratio. 

Method according to any of the preceding claims, characterized in that the said step of multiplexing by shuffling 
(152) initially comprises a step consisting in associating, with each block to be multiplexed, a variable obtained by 
applying a first evaluation criterion, then, for the construction of the multiplex, the following steps, repeated itera- 
tively for alt the symbols to be multiplexed: 

e) selecting, as a function of a second evaluation criterion pertaining to the said associated variables, one of 
the blocks to be multiplexed; 

f) extracting from the selected block the next remaining symbol when considering a given order of reading in 
35 the selected block; 

g) inserting the extracted symbol at the end of the multiplex; and 

h) re-updating the variable associated with the selected block. 

10. Method according to any of the dependent claims, characterized in that the said step of multiplexing by shuffling 
40 (1 52) is implemented on data blocks the number and size of which vary dynamically from one multiplexing frame 

to the next. 

11. Method according to any of the preceding claims, characterized in that it is implemented within a radio-communi- 
cation system implementing CDMA technology. 

45 

12. Device for interleaving and multiplexing data conveyed within several transport channels (100) distributed into 
groups of transport channels, the transport channels of one and the same group all having the same quality of 
service, comprising: 

so - a processing chain (103A, 103B) specific to each group of transport channels, allowing the processing of the 

data of the transport channels of one and the same group, each processing chain (103A, 103B) comprising 
at least data interleaving means (154; 156, 158), and 

multiplexing means (152) provided at the output of the processing chains (103A, 103B), 

55 characterized in that the said multiplexing means (152) provided at the output of the processing chains (103A, 

1 03B) are means of multiplexing by shuffling, and in that all the data interleaving means (1 54; 1 56, 1 58) are included 
within the said processing chains (103A, 103B). 
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1 3. Device according to Claim 1 2, characterized in that the said means of multiplexing by shuffling comprise a hardware 
accelerator (1130) making it possible to perform a sort of a set of pairs of values comprising, for each of the-said 
pairs, at least: 

an identification value (j) for a class of data blocks having an identical size of data blocks; and 
. - an error value (Ij.ep associated with each class of data blocks, the said error value (Ij, e,) making it possible 
to select, iteratively, from among the classes of data blocks to be multiplexed, the class of data blocks the 
symbols of which are to be appended to the multiplex undergoing formation; 

the said hardware accelerator (11 30) comprising: 



loading means (1150) for the said pairs of values, the said loading means (1150) making it possible to load 
into the input (DATAJN)of the said hardware accelerator (1130) at least one new pair of values ((Ij.e,),]) to be 
taken into account to form the said set of pairs of values to be sorted; 

sorting means (1140) for the pairs of values ((Ij.ejJJ), the said sorting means making it possible to perform at 
least one so-called first-order partial sort assigning the said pairs of values; and 

storage means (1160) for the said pairs of values, the said storage means (1160) making it possible to store, 
at a given instant (t), the current state of the said sort of the set of pairs of values, on the basis of a so-called 
second-order partial sort assigning the set of the said pairs of values, 

in such a way that a single second-order partial sort is sufficient for the said hardware accelerator (11 30) to deliver 
at output (DATA_OUT) a pair of values comprising: 



the current minimum error value (Ij.ej) of the set of error values; and 

the identification value (j) associated with the said minimum error value (Ij.ep. 

14. Mobile radio-communication network base station adapted for communicating with mobile stations of the same 
network, characterized in that it comprises a device according to Claim 12 or 13. 

15. Mobile radio-communication network mobile station adapted for communicating with base stations of the same 
network, characterized in that it comprises a device according to Claim 12 or 13. 
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